



# Asynchronous & Synchronous Reset Design Techniques - Part Deux

Clifford E. Cummings Sunburst Design, Inc. cliffc@sunburst-design.com www.sunburst-design.com Don Mills

LCDM Engineering

mills@lcdm-eng.com

www.lcdm-eng.com

Steve Gol son
Tril obyte Systems
sgol son@tril obyte.com
www.tril obyte.com





- Flip-flop coding styles
- Synchronous resets
- Asynchronous resets
- Design For Test (DFT) considerations ◄

**Reference slides** only

- Reset-buffer tree
  - Distributed synchronous reset flip-flops
  - Distributed asynchronous reset synchronizers
- Synthesis issues with reset nets
- Multi-clock resets





Problem: dissimilar flip-flops in the same always block



VHDL model included in the paper



# Good Multi-Flip-Flop Coding Style

use nonblocking assignments



Good partitioning -

VHDL model included in the paper

Solution: put dissimilar flip-flops in separate always blocks

```
no extra logic
 module goodFFstyle (q2, d, clk, rst n);
   output q2;
   input d, clk, rst n;
                                                                      q2
                                             rst n
   reg q2, q1;
   always @(posedge clk)
     if (!rst n) q1 <= 1'b0;
                                                  clk
     else q1 \ll d;
   always @(posedge clk)
                                                      No reset on the
     q2 <= q1; _
                                                      follower flip-flop
 endmodule
                              q2 is loaded on every
                                 posedge clk
Note: To model sequential logic
```





Synchonous reset: rst\_n is not in the sensitivity list

```
module ctr8sr (q, co, d, ld, rst n, clk);
 output [7:0] q;
 output co;
 input [7:0] d;
 input ld, rst_n, clk;
                               rst n not in the
 reg [7:0] q;
                                sensitivity list
           co;
 reg
 always @(posedge clk)
   if (!rst_n)*{co,q} <= 9'b0; // sync reset
   else if (ld) \{co,q\} \le d; // sync load
                   \{co,q\} \ll q + 1'b1; // sync increment
   else
endmodule
```

VHDL model included in the paper

VHDL versions would have required too many slides to show the same models ...

... or a microscopic font



# Synchronous Resets Synthesis Results #1







### Synchronous Resets Synthesis Results #2



Synthesis tools could locate synchronous resets signals poorly

Add this directive to avoid badly placed synchronous reset signals

```
q
rst n
                   sel1
ld
    Synchronous rst_n
   and-gates are outside
         the mux
                                          CO
          clk
```

```
// synopsys sync set reset "rst n"
always @(posedge clk)
    (!rst_n) \{co,q\} <= 9'b0;
 if
 else if (ld) \{co,q\} \le d;
                  \{co,q\} <= q + 1'b1;
 else
```





Asynchonous reset: rst\_n is in the sensitivity list

```
module ctr8ar (q, co, d, ld, rst n, clk);
 output [7:0] q;
 output co;
 input [7:0] d;
 input ld, rst_n, clk;
                                rst n is in the
 reg [7:0] q;
                                 sensitivity list
 reg
           co;
 always @(posedge clk or negedge rst_n)
   if (!rst_n)^{4}\{co,q\} \le 9'b0; // async reset
   else if (ld) \{co,q\} \le d; // sync load
                   \{co,q\} \ll q + 1'b1; // sync increment
   else
endmodule
```

VHDL model included in the paper



# Synthesizing Asynchronous Resets



Only clk or rst\_n can cause the outputs to change

clk or rst\_n can trigger the always block



always @(posedge clk or negedge rst\_n) if  $(!rst_n) \{co,q\} <= 9'b0;$ else if (ld)  $\{co,q\} \ll d$ ;  $\{co,q\} <= q + 1'b1;$ else

asynchronous rst\_n, in the sensitivity list

synchronous 1d not in the sensitivity list



#### Advantages

- Easier to work with cycle based simulators (according to the RMM)
- Typically recommended for DFT design
- Glitch filtering from reset combinational logic (to make up for poor design practices)
- Glitch filtering if reset is in a mission-critical application

#### Disadvantages

- May not be able to come out of Unknown-X during simulation
- May add delay to data path
- Power-up reseting of a tri-state bus ◆

... but there is a solution!



#### Tri-State Enable Drivers







## Asynchronous Resets

#### Advantages & Disadvantages



#### Advantages

- Reset is immediate
- No problem related to Unknown-X-propagation in design simulation
- Does not interfere or add extra delay to the data path
- Very easy to implement on the front end





#### Asynchronous Reset Problem



- Problem: <u>Asynchronous</u> reset removal
  - Will reset removal meet recovery time specification?



Potential problem: flip-flop could go metastable on reset-release if reset removal violates clock set/hold time



#### Flawed Reset Synchronizer (ESNUG 409 Item 11)



Reset Flawed recommendation by one ESNUG reader distribution buffer tree And-gate added to remove reset metastability if reset is asserted too close to the active clock edge (NOTE: this is not a real problem) May change clock polarity if necessary to fix reset removal timing issues chip\_rst\_n clk pad\_clk rst n pad\_rst\_n Behavior is almost the **Asynchronous-reset** same for synchronous flip-flop NOTE: this design is still or asynchronous reset subject to metastability



## Flawed Reset RTL Thinking



(ESNUG 409 - Also Item 11)

Flawed RTL coding thoughts by another ESNUG reader

"One reason not to use asynchronous resets is that Verilog cannot model them without a race condition. Typical async reset flop:

```
always @ (posedge ck or negedge rst) begin
  if (!rst) q <= 0;
  else          q <= d;
end</pre>
```

A real hardware reset recovery violation!

"What happens when rst is DEasserted at the same time as ck is asserted? Either ck goes high first, and rst is still low, so q gets zero.

Or rst goes high first, and when ck fires, q gets d.

Uh-oh. Do you get your new d or not?"

This is not a Verilog race condition, this is a hardware race condition!

**Even with VHDL delta-times this same "race" condition exists** 



### Flawed Reset RTL Thinking

\_\_Sunburst Design\_

(ESNUG 409 - Also Item 11 - continued)

Upon further investigation, the real issue was poor testbench practices

Users remove reset on the posedge clk in testbenches (What?? No Way!!)

Non-deterministic behavior between RTL and gates (and between different vendors)

Users blame EDA vendors when RTL differs from gates simulations

**EDA** vendors cannot fix real hardware race conditions!

Don't be a stupid user! Don't try removing reset on a posedge clk in the testbench! It doesn't work in simulations because it doesn't work in real hardware!!



### Reset Synchronizer



- Advantage: <u>Asynchronous</u> reset assertion
- Advantage: <u>Synchronous</u> reset removal





### Synchronous Reset Removal Solution



- Advantage: <u>Synchronous</u> reset removal
  - Predictable reset removal to meet recovery time specification!



# Reset Synchronizer

Verilog RTL Code





**Guideline: EVERY ASIC USING** AN ASYNCHRONOUS RESET SHOULD INCLUDE A RESET SYNCHRONIZER CIRCUIT!!

```
module reset_synchronizer (masterrst_n, clk, rst_n);
  output masterrst n;
  input clk, rst n;
         rst n, rff1;
  reg
  always @(posedge clk or negedge rst n)
    if (!rst_n) {masterrst_n,rff1} <= 2'b0;</pre>
                 {masterrst_n,rff1} <= {rff1,1'b1}; ←</pre>
    else
endmodule
```

**Asynchronous** reset assertion (on negedge rst\_n)

**Synchronous** reset removal (on posedge clk)

Concatenation makes for efficient coding of the reset synchronizer



### Synchronizer Metastability??





- FAQ: Can the 2nd flip-flop of the synchronizer go metastable if rst\_n is removed too close to a posedge clk (violating reset recovery time)?
- Answer: NO !!





### Reset Removal Metastability??



Example flip-flop implementation





# Different Reset Synchronizer

\_\_\_\_Sunburst Design\_

(ESNUG 409 - Also Item 11)

Tie the synchronizer data input to the reset input signal





### Synopsys Reset Switches







# Clock & Reset Loading







### Reset Buffer Tree









### Reset Buffer Tree









### Synchronous Reset Distribution using Flip-Flops

Sunburst Desian Input reset flip-flop in each module



For the reset RTL in each module // synopsys sync\_set\_reset <reset\_name>



# Asynchronous Reset Glitch Filtering



- Glitches on the rst\_n input might cause stray resets
- Solution: glitch-filter on the rst\_n input





### Asynchronous Reset & DFT \_\_Sunburst Design\_



- The process of applying the ATPG vectors to create a test is based on:
  - scanning a known state into all the flip-flops in the chip
  - switching the flip-flops from scan shift mode, to functional data input mode
  - applying one functional clock
  - switching the flip-flops back to scan shift mode to scan out the result of the one functional clock while scanning in the next test vector
  - During the above process, the designer must insure that under NO CONDITIONS, an asynchronous set/reset can occur and thus corrupt the input vectors

    The asynchronous reset must be held in

the inactive state during the entire test

What about coverage to the portion of the chip controlled by the reset?



### Asynchronous Reset & DFT



- Can I use an asynchronous reset with Design For Test (DFT) strategies?
  - scan in all ones into the scan chain
  - issue and release the asynchronous reset
  - scan out the result and scan in all zeros
  - issue and release the reset
  - scan out the result
  - set the reset input to the non reset state and then apply the ATPG generated vectors

This will test for the reset line attached to either the asynchronous set or reset of a flip-flop



# Multiple Clock Domains



Non-Synchronized Reset Removal





# Multiple Clock Domains



Synchronized Reset Removal







- Synchronous resets:
  - Add "synopsys sync\_set\_reset" directive to optimize synchronous reset layout (and minimize X-state simulation problems)
  - Easiest solution for doing Static Timing Analysis (STA)
  - Easiest solution when working with DFT
- Asynchronous resets and the "Reset Synchronizer":
  - Offers the advantages of asynchronous resets
  - Offers the advantages of synchronous reset removal
  - Still works well with DFT techniques
  - Reset path is not as easily checked using STA
- Know the limitations of each reset strategy
  - If you do it wrong it is gonna hurt!